package com.wcj.hash.hashset;

import java.util.HashSet;
import java.util.Set;

/**
 * 编写一个算法来判断一个数 n 是不是快乐数。
 *
 * 「快乐数」 定义为：
 *
 * 对于一个正整数，每一次将该数替换为它每个位置上的数字的平方和。
 * 然后重复这个过程直到这个数变为 1，也可能是 无限循环 但始终变不到 1。
 * 如果这个过程 结果为 1，那么这个数就是快乐数。
 * 如果 n 是 快乐数 就返回 true ；不是，则返回 false 。
 */
public class 快乐数 {

    public boolean isHappy(int n) {
       int sum = 0;
       Set<Integer> see = new HashSet<>();
       while (n != 1 && !see.contains(n)){
           see.add(n);
           while (n > 0){
               int d = n%10;
               sum += d*d;
               n /= 10;
           }
           n = sum;
           sum = 0;
       }
      return n == 1;
    }
}
